<!DOCTYPE html>
<html lang=zh>
<head>
    <!-- so meta -->
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="HandheldFriendly" content="True">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
    <meta name="description" content="一个cron表达式有至少6个（也可能7个）有空格分隔的时间元素。按顺序依次为：  秒（0~59） 分钟（0~59） 小时（0~23） 天（0~31） 月（0~11） 星期(写法1：1~7 1&#x3D;SUN；写法2：SUN,MON,TUE,WED,THU,FRI,SAT) 年份(1970-2099)  其中每个元素可以式一个值（如6），一个连续区间（9-12），一个间隔时间（8-18&#x2F;4）（&#x2F;4表示每隔4">
<meta property="og:type" content="article">
<meta property="og:title" content="cron表达式学习">
<meta property="og:url" content="https:&#x2F;&#x2F;fengzxia.gitee.io&#x2F;posts&#x2F;9c0cd83e.html">
<meta property="og:site_name" content="只是学习学习的博客">
<meta property="og:description" content="一个cron表达式有至少6个（也可能7个）有空格分隔的时间元素。按顺序依次为：  秒（0~59） 分钟（0~59） 小时（0~23） 天（0~31） 月（0~11） 星期(写法1：1~7 1&#x3D;SUN；写法2：SUN,MON,TUE,WED,THU,FRI,SAT) 年份(1970-2099)  其中每个元素可以式一个值（如6），一个连续区间（9-12），一个间隔时间（8-18&#x2F;4）（&#x2F;4表示每隔4">
<meta property="og:locale" content="zh_CN">
<meta property="article:published_time" content="2019-04-04T07:33:17.000Z">
<meta property="article:modified_time" content="2020-04-16T12:11:08.960Z">
<meta property="article:author" content="只是学习学习">
<meta property="article:tag" content="定时任务">
<meta property="article:tag" content="cron表达式">
<meta name="twitter:card" content="summary">
    
    
        
          
              <link rel="shortcut icon" href="/images/favicon.ico">
          
        
        
          
            <link rel="icon" type="image/png" href="/images/favicon-192x192.png" sizes="192x192">
          
        
        
          
            <link rel="apple-touch-icon" sizes="180x180" href="/images/apple-touch-icon.png">
          
        
    
    <!-- title -->
    <title>cron表达式学习</title>
    <!-- styles -->
    
<link rel="stylesheet" href="/css/style.css">

    <!-- persian styles -->
    
      
<link rel="stylesheet" href="/css/rtl.css">

    
    <!-- rss -->
    
    
    
<meta name="generator" content="Hexo 4.1.1"></head>

<body class="max-width mx-auto px3 ltr">
    
      <div id="header-post">
  <a id="menu-icon" href="#"><i class="fas fa-bars fa-lg"></i></a>
  <a id="menu-icon-tablet" href="#"><i class="fas fa-bars fa-lg"></i></a>
  <a id="top-icon-tablet" href="#" onclick="$('html, body').animate({ scrollTop: 0 }, 'fast');" style="display:none;"><i class="fas fa-chevron-up fa-lg"></i></a>
  <span id="menu">
    <span id="nav">
      <ul>
         
          <li><a href="/">主页</a></li>
         
          <li><a href="/archives/">归档</a></li>
         
          <li><a href="/categories/">分类</a></li>
         
          <li><a href="/tags/">标签</a></li>
         
          <li><a href="/search/">搜索</a></li>
         
          <li><a href="/about/">关于</a></li>
         
          <li><a href="/friend_ship/">友链</a></li>
        
      </ul>
    </span>
    <br/>
    <span id="actions">
      <ul>
        
        <li><a class="icon" href="/posts/73978cee.html"><i class="fas fa-chevron-left" aria-hidden="true" onmouseover="$('#i-prev').toggle();" onmouseout="$('#i-prev').toggle();"></i></a></li>
        
        
        <li><a class="icon" href="/posts/493442a1.html"><i class="fas fa-chevron-right" aria-hidden="true" onmouseover="$('#i-next').toggle();" onmouseout="$('#i-next').toggle();"></i></a></li>
        
        <li><a class="icon" href="#" onclick="$('html, body').animate({ scrollTop: 0 }, 'fast');"><i class="fas fa-chevron-up" aria-hidden="true" onmouseover="$('#i-top').toggle();" onmouseout="$('#i-top').toggle();"></i></a></li>
        <li><a class="icon" href="#"><i class="fas fa-share-alt" aria-hidden="true" onmouseover="$('#i-share').toggle();" onmouseout="$('#i-share').toggle();" onclick="$('#share').toggle();return false;"></i></a></li>
      </ul>
      <span id="i-prev" class="info" style="display:none;">上一篇</span>
      <span id="i-next" class="info" style="display:none;">下一篇</span>
      <span id="i-top" class="info" style="display:none;">返回顶部</span>
      <span id="i-share" class="info" style="display:none;">分享文章</span>
    </span>
    <br/>
    <div id="share" style="display: none">
      <ul>
  <li><a class="icon" href="http://www.facebook.com/sharer.php?u=https://fengzxia.gitee.io/posts/9c0cd83e.html" target="_blank" rel="noopener"><i class="fab fa-facebook " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://twitter.com/share?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&text=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-twitter " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://www.linkedin.com/shareArticle?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-linkedin " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://pinterest.com/pin/create/bookmarklet/?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&is_video=false&description=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-pinterest " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="mailto:?subject=cron表达式学习&body=Check out this article: https://fengzxia.gitee.io/posts/9c0cd83e.html"><i class="fas fa-envelope " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://getpocket.com/save?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-get-pocket " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://reddit.com/submit?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-reddit " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://www.stumbleupon.com/submit?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-stumbleupon " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://digg.com/submit?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-digg " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://www.tumblr.com/share/link?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&name=cron表达式学习&description=" target="_blank" rel="noopener"><i class="fab fa-tumblr " aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://news.ycombinator.com/submitlink?u=https://fengzxia.gitee.io/posts/9c0cd83e.html&t=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-hacker-news " aria-hidden="true"></i></a></li>
</ul>

    </div>
    <div id="toc">
      
    </div>
  </span>
</div>

    
    <div class="content index py4">
        
        <article class="post" itemscope itemtype="http://schema.org/BlogPosting">
  <header>
    
    <h1 class="posttitle" itemprop="name headline">
        cron表达式学习
    </h1>



    <div class="meta">
      <span class="author" itemprop="author" itemscope itemtype="http://schema.org/Person">
        <span itemprop="name">只是学习学习的博客</span>
      </span>
      
    <div class="postdate">
      
        <time datetime="2019-04-04T07:33:17.000Z" itemprop="datePublished">2019-04-04</time>
        
      
    </div>


      

      
    <div class="article-tag">
        <i class="fas fa-tag"></i>
        <a class="tag-link" href="/tags/cron%E8%A1%A8%E8%BE%BE%E5%BC%8F/" rel="tag">cron表达式</a>, <a class="tag-link" href="/tags/%E5%AE%9A%E6%97%B6%E4%BB%BB%E5%8A%A1/" rel="tag">定时任务</a>
    </div>


    </div>
  </header>
  

  <div class="content"itemprop ="articleBody">
    <p>一个cron表达式有至少6个（也可能7个）有空格分隔的时间元素。按顺序依次为：</p>
<ul>
<li>秒（0~59）</li>
<li>分钟（0~59）</li>
<li>小时（0~23）</li>
<li>天（0~31）</li>
<li>月（0~11）</li>
<li>星期(写法1：1~7 1=SUN；写法2：SUN,MON,TUE,WED,THU,FRI,SAT)</li>
<li>年份(1970-2099)</li>
</ul>
<p>其中每个元素可以式一个值（如6），一个连续区间（9-12），一个间隔时间（8-18/4）（/4表示每隔4小时），一个列表（1,3,5），通配符。由于”日期”和”星期”这两个元素互斥的，必须要对其中一个设置。</p>
<p>配置实列：</p>
<ul>
<li>每个5秒执行一次: <code>/5 * ?</code></li>
<li>每隔1分钟执行一次: <code>0 /1 ?</code></li>
<li>每天上午10点，下午两点，4点: <code>0 0 10,14,16 ?</code></li>
<li>朝九晚五工作时间内每半小时: <code>0 0/30 9-17 ?</code></li>
<li>表示每个星期三中午12点: <code>0 0 12 ? * WED</code></li>
<li>每天中午12点触发: <code>0 0 12 ?</code></li>
<li>每天上午10:15触发(结尾有空格,为了方便看清加了引号): <code>&quot;0 15 10 ? &quot;</code></li>
<li>每天上午10:15触发: <code>0 15 10 ?</code></li>
<li>每天上午10:15触发: <code>0 15 10 ? *</code></li>
<li>2005年每天上午10:15触发: <code>0 15 10 ? 2005</code></li>
<li>在每天下午2点到下午2:59期间的每1分钟触发: <code>0 14 * ?</code></li>
<li>在每天下午2点到下午2:55期间的每5分钟触发: <code>0 0/5 14 ?</code></li>
<li>在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发: <code>0 0/5 14,18 ?</code></li>
<li>在每天下午2点到下午2:05期间的每1分钟触发: <code>0 0-5 14 ?</code></li>
<li>每年三月的星期三的下午2:10和2:44触发: <code>0 10,44 14 ? 3 WED</code></li>
<li>周一至周五的上午10:15触发: <code>0 15 10 ? * MON-FRI</code></li>
<li>每月15日上午10:15触发: <code>0 15 10 15 * ?</code></li>
<li>每月最后一日的上午10:15触发: <code>0 15 10 L * ?</code></li>
<li>每月的最后一个星期五上午10:15触发: <code>0 15 10 ? * 6L</code></li>
<li>2002年至2005年的每月的最后一个星期五上午10:15触发: <code>0 15 10 ? * 6L 2002-2005</code></li>
<li>每月的第三个星期五上午10:15触发: <code>0 10 10 ? * 6#3</code></li>
</ul>
<p>有些子表达式能包含一些范围或列表<br>例如: 子表达式(星期)可以为 <code>MON-FRI</code>, <code>MON,WED,FRI</code>, <code>MON-WED,SAT</code>, <code>*</code>字符代表所有可能的值,<code>/</code>字符用来指定数值的增量</p>
<p>例如: 在子表达式(分钟)里的 <code>0/15</code> 表示从第0分钟开始，每15分钟在子表达式(分钟)里的 <code>3/20</code> 表示从第3分钟开始，每20分钟(它和<code>3,23,43</code>)的含义一样 <code>?</code> 字符仅被用于 “日期” 和 “星期” 两个子表达式，表示不指定值，当两个子表达式其中之一被指定了值以后，为了避免冲突，需要将另一个子表达式的值设置为<code>?</code></p>
<p><code>L</code> 字符仅被用于”日期”和”星期”两个子表达式，它是单词”last”的缩写如果在”L”前有具体的内容，它就具有其他的含义了。</p>
<p>例如: “6L” 表示这个月的倒数第6天 <strong>在使用“L”参数时，不要指定列表或范围，因为这会导致问题”W”字符代表着“平日(Mon-Fri)”，并且仅能用于日期中。它用来指定日离指定日最近的一个平日。大部分的商业处理都是基于工作周的，所以 W 字符可能是非常重要的</strong>  </p>
<p>例如，日期中的<code>15W</code>意味着“离该月15号的最近一个平日。”假如15号是星期六，那么trigger会在14号（星期五）触发，因为星期四比星期一离15号更近。C: 代表“Calendar”的意思。它的意思是计划所关联的日期，如果日期没有被关联，则相当于日历中所有日期。</p>
<p>例如，5C在日期字段就相当于日历5日以后的第一天。1C在星期字段中相当于星期日后的第一天</p>
<table>
<thead>
<tr>
<th>字段</th>
<th>允许值</th>
<th>允许的特殊字符</th>
</tr>
</thead>
<tbody><tr>
<td>秒</td>
<td>0~59</td>
<td>, - * /</td>
</tr>
<tr>
<td>分</td>
<td>0~59</td>
<td>, - * /</td>
</tr>
<tr>
<td>小时</td>
<td>0~23</td>
<td>, - * /</td>
</tr>
<tr>
<td>日期</td>
<td>1-31</td>
<td>, - * ? / L W C</td>
</tr>
<tr>
<td>月份</td>
<td>1<del>12或者JAN</del>DEC</td>
<td>, - * /</td>
</tr>
<tr>
<td>星期</td>
<td>1<del>7或者SUN</del>SAT</td>
<td>, - * ? / L C #</td>
</tr>
<tr>
<td>年(可选)</td>
<td>留空，1970~2099</td>
<td>, - * /</td>
</tr>
</tbody></table>

<div id="gitalk-container"></div>
<script src="https://cdn.bootcss.com/blueimp-md5/2.12.0/js/md5.min.js"></script><link rel="stylesheet" href="https://unpkg.com/gitalk/dist/gitalk.css"><script src="https://unpkg.com/gitalk/dist/gitalk.min.js"></script>

		<script>
		var gitalkConfig = {"clientID":"28a065e3b5afee156f4f","clientSecret":"e18104d6f3219526491fc42c892ff6a26b8f3e74","repo":"blog_comment","owner":"FENG1000","admin":["FENG1000"],"distractionFreeMode":false};
	    gitalkConfig.id = md5(location.pathname);
		var gitalk = new Gitalk(gitalkConfig);
	    gitalk.render("gitalk-container");
	    </script>
    
  <blockquote>
      <p>
          作者: 只是学习学习<br>
          邮箱: fengzxia1000@163.com<br>
          原文地址: <a href="https://fengzxia.gitee.io/posts/9c0cd83e.html" target="_blank" rel="noopener">https://fengzxia.gitee.io/posts/9c0cd83e.html</a><br>
          版权声明: 商业转载请联系作者获得授权，非商业转载请注明出处。
      </p>
  </blockquote>

  <script>
      function setClipboardText(event){
          // clipboardData 对象是为通过编辑菜单、快捷菜单和快捷键执行的编辑操作所保留的，也就是你复制或者剪切内容
          let clipboardData = event.clipboardData || window.clipboardData;
          // 如果未复制或者未剪切，则return出去
          if (!clipboardData) { return; }
          event.preventDefault();
          // Selection 对象，表示用户选择的文本范围或光标的当前位置。
          //     声明一个变量接收 -- 用户输入的剪切或者复制的文本转化为字符串
          let text = window.getSelection().toString();

          if (text) {
            // 如果文本存在则先取消文本默认事件
            event.preventDefault();
            // 通过调用常clipboardData对象的 setData(format, data) 方法；来设置相关文本
            // format: 一个DOMString 表示要添加到 drag object的拖动数据的类型。
            // data: 一个 DOMString表示要添加到 drag object的数据。
            var copyright = '\n\n'
                            + '\n著作权归作者所有。'
                            + '\n商业转载请联系作者获得授权，非商业转载请注明出处。'
                            + '\n作者: 只是学习学习'
                            + '\n邮箱: fengzxia1000@163.com'
                            + '\n原文地址: https://fengzxia.gitee.io/posts/9c0cd83e.html'

            clipboardData.setData('text/plain', text + copyright);

          }
      };
      var contents = document.getElementsByClassName("content");
      // 监听文章内容的copy事件
      contents[0].addEventListener('copy',function(e){
          setClipboardText(e);
      });
  </script>

  </div>
</article>




        
          <div id="footer-post-container">
  <div id="footer-post">

    <div id="nav-footer" style="display: none">
      <ul>
         
          <li><a href="/">主页</a></li>
         
          <li><a href="/archives/">归档</a></li>
         
          <li><a href="/categories/">分类</a></li>
         
          <li><a href="/tags/">标签</a></li>
         
          <li><a href="/search/">搜索</a></li>
         
          <li><a href="/about/">关于</a></li>
         
          <li><a href="/friend_ship/">友链</a></li>
        
      </ul>
    </div>

    <div id="toc-footer" style="display: none">
      
    </div>

    <div id="share-footer" style="display: none">
      <ul>
  <li><a class="icon" href="http://www.facebook.com/sharer.php?u=https://fengzxia.gitee.io/posts/9c0cd83e.html" target="_blank" rel="noopener"><i class="fab fa-facebook fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://twitter.com/share?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&text=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-twitter fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://www.linkedin.com/shareArticle?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-linkedin fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://pinterest.com/pin/create/bookmarklet/?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&is_video=false&description=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-pinterest fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="mailto:?subject=cron表达式学习&body=Check out this article: https://fengzxia.gitee.io/posts/9c0cd83e.html"><i class="fas fa-envelope fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://getpocket.com/save?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-get-pocket fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://reddit.com/submit?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-reddit fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://www.stumbleupon.com/submit?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-stumbleupon fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://digg.com/submit?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&title=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-digg fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="http://www.tumblr.com/share/link?url=https://fengzxia.gitee.io/posts/9c0cd83e.html&name=cron表达式学习&description=" target="_blank" rel="noopener"><i class="fab fa-tumblr fa-lg" aria-hidden="true"></i></a></li>
  <li><a class="icon" href="https://news.ycombinator.com/submitlink?u=https://fengzxia.gitee.io/posts/9c0cd83e.html&t=cron表达式学习" target="_blank" rel="noopener"><i class="fab fa-hacker-news fa-lg" aria-hidden="true"></i></a></li>
</ul>

    </div>

    <div id="actions-footer">
        <a id="menu" class="icon" href="#" onclick="$('#nav-footer').toggle();return false;"><i class="fas fa-bars fa-lg" aria-hidden="true"></i> 菜单</a>
        <a id="toc" class="icon" href="#" onclick="$('#toc-footer').toggle();return false;"><i class="fas fa-list fa-lg" aria-hidden="true"></i> 目录</a>
        <a id="share" class="icon" href="#" onclick="$('#share-footer').toggle();return false;"><i class="fas fa-share-alt fa-lg" aria-hidden="true"></i> 分享</a>
        <a id="top" style="display:none" class="icon" href="#" onclick="$('html, body').animate({ scrollTop: 0 }, 'fast');"><i class="fas fa-chevron-up fa-lg" aria-hidden="true"></i> 返回顶部</a>
    </div>

  </div>
</div>

        
        <footer id="footer">
  <div class="footer-left">
    Copyright &copy;
    
    
    2019-2020
    只是学习学习
  </div>
  <div class="footer-right">
    <nav>
      <ul>
         
          <li><a href="/">主页</a></li>
         
          <li><a href="/archives/">归档</a></li>
         
          <li><a href="/categories/">分类</a></li>
         
          <li><a href="/tags/">标签</a></li>
         
          <li><a href="/search/">搜索</a></li>
         
          <li><a href="/about/">关于</a></li>
         
          <li><a href="/friend_ship/">友链</a></li>
        
      </ul>
    </nav>
  </div>
</footer>

    </div>
    <!-- styles -->

<link rel="stylesheet" href="/lib/font-awesome/css/all.min.css">


<link rel="stylesheet" href="/lib/justified-gallery/css/justifiedGallery.min.css">


    <!-- jquery -->

<script src="/lib/jquery/jquery.min.js"></script>


<script src="/lib/justified-gallery/js/jquery.justifiedGallery.min.js"></script>

<!-- clipboard -->

  
<script src="/lib/clipboard/clipboard.min.js"></script>

  <script type="text/javascript">
  $(function() {
    // copy-btn HTML
    var btn = "<span class=\"btn-copy tooltipped tooltipped-sw\" aria-label=\"复制到粘贴板!\">";
    btn += '<i class="far fa-clone"></i>';
    btn += '</span>'; 
    // mount it!
    $(".highlight table").before(btn);
    var clip = new ClipboardJS('.btn-copy', {
      text: function(trigger) {
        return Array.from(trigger.nextElementSibling.querySelectorAll('.code')).reduce((str,it)=>str+it.innerText+'\n','')
      }
    });
    clip.on('success', function(e) {
      e.trigger.setAttribute('aria-label', "复制成功!");
      e.clearSelection();
    })
  })
  </script>


<script src="/js/main.js"></script>

<!-- search -->

<!-- Google Analytics -->

<!-- Baidu Analytics -->

    <script type="text/javascript">
        var _hmt = _hmt || [];
        (function() {
            var hm = document.createElement("script");
            hm.src = "https://hm.baidu.com/hm.js?54382acbd8c4bc66535bce135e0ac166";
            var s = document.getElementsByTagName("script")[0];
            s.parentNode.insertBefore(hm, s);
        })();
    </script>

<!-- Disqus Comments -->


</body>
<script>
(function(){
    var bp = document.createElement('script');
    var curProtocol = window.location.protocol.split(':')[0];
    if (curProtocol === 'https'){
   bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
  }
  else{
  bp.src = 'http://push.zhanzhang.baidu.com/push.js';
  }
    var s = document.getElementsByTagName("script")[0];
    s.parentNode.insertBefore(bp, s);
})();
</script>
</html>
